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(57) Abstract 

Turbo^oding in a communications system involves coding/decoding information in stages in order to avoid retransmission of a full 
L-bit packet upon occurrence of a packet eiror. In addition to a set of code bits generaied by an encoder usmg a turbo^odmg scheme, 
a punctured set of code bits is generated and stored in transmitter memory. The original set of code bits is transmitted as an L-bit cata 
packet to a receiver which stores received data samples corresponding to the original set of code bits. The receiver decodes the data pac:<et 
using a turbo-<iecoder and determines whether the data packet has been received in error. If so, the received data samples are maintained 
in memory and a request for more information is made. Some or all of the punctured infonmation is then forwarded from the transmitter 
to the receiver. A second stage of turbcn-decoding combines the new data samples with the stored original received data samples such that 
there is a high likelihood that decoding is correct at this point, but additional stages of decoding may be used. 
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TURBO-CODING WITH STAGED DATA 
TRANSMISSION AND PROCESSING 



BACKGROUND OF THE INVENTION 

The present invention relates generally to coding in 
communications systems and, more particularly, to turbo-coding 
5 information in stages. 

Turtjo-coding is known in the art as another term for 
parallel concatenated convolutional coding. More specifically, turbo- 
coding involves encoding an information sequence twice, the second 
encoding being performed after a random interleaving of the 
10 information sequence. Decoding is performed iteratively, and the 
result is reliable communication. 

in many communications systems, data is transmitted 
in L-bit packets, where L is typically on the order of between ten and 
several hundred. If the receiver determines that the packet has been 
15 received in error, there may be a request to retransmit the 

information, referred to as an automatic repeat request (ARQ). 
Disadvantageously, this results in the transmission of a total of 2L 
bits. 

Accordingly, it is desirable to provide a method and 
20 apparatus for turbo-coding which does not require a full L-bit packet 
to be retransmitted upon occurrence of a packet error. 

SUMMARY OF THE INVENTION 

A method and apparatus for turtDO-coding stages of 
information in a communications system avoids retransmission of a 
full L-bit packet upon occun-ence of a packet en-or. In accordance 

25 therewith, in addition to a set of code bits generated by an encoder 
using a turbo-coding scheme, a punctured set of code bits is 
generated and stored in transmitter memory. The original set of code 
bits is transmitted as an L-bit data packet, via a channel, to a receiver 
which stores the received data samples corresponding to the onginal 

30 set of code bits. The receiver decodes the data packet using a turbo- 
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decoder and determines whether the data packet has been received 
in error. If so, the received data samples are maintained in memory, 
and a request for more information is made. Some or all of the 
punctured infonmation is then fonvarded from the transmitter, via the 
5 channel, to the receiver. A second stage of turtK>decoding combines 
the new (i.e., punctured) data samples with the stored original 
received data samples. Decoding is likely to be correct at this point. 
However, it may t>e desirable to have three or more transmission 
stages of decoding, depending upon the application. 

BRIEF DESCRIPTION OF THE DRAWING 
10 FIG. 1 is a block diagram illustrating a turbo-coding 

scheme with staged information transmission according to an 
embodiment of the present invention; 

FIG. 2 Is a block diagram illustrating turbo-coding with 
staged information transmission using rate 1/3 with systematic 
15 encoders according to an embodiment of the present invention; 

FIG. 3 is a block diagram illustrating a staged decoder 
according to an embodiment of the present invention; 

FIG. 4 is a flow chart illustrating staged information 
turtx>-coding, i.e.. at the transmitter, according to an embodiment of 
20 the present invention; and 

FIG. 5 is a flow chart illustrating stage infomiation turbo- 
decoding according to an embodiment of the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

FIG. 1 illustrates a turtXK^ding scheme with staged 
information transmission according to an embodiment of the present 

2 5 invention. In FIG. 1, a turbo encoder 12 encodes source information 
using a parallel concatenation of two convolutional codes in encoder 
14 and in encoder 16, typically referred to in the art as Encoder 1 and 
Encoder 2. respectively. The second encoder, encoder 16, performs 
the second encoding after random interleaving in an interleaver 18. 

30 The code bits C1 and C2 are transmitted via a channel 

to a receiver 19. A set of data samples corresponding to the original 
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transmitted code bits CI and C2 from encoder 16 and encoder 18, 
respectively, are received by receiver 19 and stored in receiver 
memory. A punctured set of code bits P1 and P2, respectively, 
corresponding to code bits C1 and C2, respectively, is also 
5 generated by encoder 12 and stored in transmitter memory 20 and 
memory 22, respectively. 

As known in the art, an encoder applies a puncturing 
process to a convoiutional code by deleting some output bits 
according to a predetermined puncturing pattern in order to increase 

10 the rate of the resulting code. The associated decoder in receiver 19 
includes a corresponding depuncturing function which involves 
inserting a neutral value for each known punctured bit. The size of 
the punctured set of code brts is determined by the bandwidth, power, 
and retransmission frequency of the system. 

15 Receiver 19 decodes the data by turt>o-decoding and 

determines whether the packet has been received in error If so, then 
the received data samples comesponding to code bits C1 and C2 are 
maintained in memory. The receiver makes a request for more 
information, whereby some or all of the stored punctured bits are 

20 transmitted, via the channel, to the receiver. A second stage of turbo- 
decoding is performed, combining the data samples corresponding 
to punctured code bits P1 and P2 with the original received data 
samples comesponding to code bits C1 and C2. Advantageously, it 
is highly likely that decoding is con-ect at this point, resulting in highly 

25 reliable communication. However, depending upon the application, 
three or more transmission stages of turbo-decoding may be 
desirable. 

Turbo-coding commonly involves the use of systematic 
convoiutional codes for which input bits appear directly in the code 

30 output. To increase the rate of such a code, another fomi of 

puncturing may be applied wherein only one copy of the systematic 
bits is transmitted, which copy is used by all convoiutional decoders 
in the turbo-decoding process. The staged transmission process 
described hereinabove may be applied to this form of puncturing as 

35 well. In particular, If a packet is received in error, a retransmission of 
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the systematic bits is requested with the newly received samples 
applied to one or more convolutional decoders of the turbo-decoding 
algorithm. 

FIG. 2 illustrates an example of turtxD-decoding of a 
5 systematic code with staged information transmission. In this 

example, a rate 1/3 turbo code is created by transmitting the full code 
output of a rate 1/2 systematic convolutional encoder 24 operating on 
the original input sequence while transmitting only the parity bits of a 
second systematic convolutional encoder 26. also rate 1/2. operating 

10 on an interieaved copy of the input sequence. At a receiver 29. the 
received data samples con-esponding to the systematic bits are used 
for both of the convolutional decoding components of the turbo code. 
The receiver requests a second copy of the systematic bits via 
memory 30 only rf the first attempt at decoding results in a detected 

15 packet en-or. The received data samples corresponding to the 
second copy of the systematic bits is used for the second 
convolutional decoder component. Advantageously, the newly 
requested information is only 1/3 of the number of transmitted bits 
required in the classical automatic repeat request (ARQ) scheme. 

20 FIG. 3 illustrates a staged turbo decoder 40 in a receiver 

according to an embodiment of the present invention. The input to 
decoder 40 is controlled by an input data selector 42. The received 
data samples con-esponding to the transmitted code bits are copied 
into memory 44 in the first stage of transmission and are used in 

25 each iteration in the turbo decoding process. Memory 44 also allows 
systematic information that is common to encoder 1 and encoder 2 
(FlGs. 1 and 2) to be transmitted only once in the first stage of turbo 
decoding. In the first stage of decoding, the data selector chooses A 
when the infonnation has been punctured and chooses B when the 

30 received data samples are available. Memory 44 is addressed by the 
non-interleaving sequence when encoder 1 data is processed and by 
the interleaving sequence when encoder 2 data is processed. 

After the first stage of turbo-decoding, a packet error 
detection mechanism 50 determines whether the data was received 
3 5 correctly. An exemplary packet error detection mechanism 
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comprises a well-known 16-bit cydic redundancy check (CRC) code 
As described hereinabove, if a packet error is detected, a request for 
transmission of infomiatlon previously punctured and/or for a second 
set of systematic data is made. The new infonnation is also stored 
5 in memory 44. The second stage of decoding then takes place with 
the more complete information; i.e., the previously punctured 
infonnation is combined with the new stage of infonnation and 
decoded. 

FIG. 4 is a flow chart illustrating turbo-coding at the 

10 transmitter end according to an embodiment of the present invention. 
In step 60, the first (or next) information block is provided to the 
transmitter. Step 62 involves generating and storing the stage one 
infonnation through stage N bits. Stage i bits are transmitted in step 
64. After the receiver determines whether there has been a packet 

15 transmission error, an indication of same is given to the transmitter 
in step 66. If positive acknowledgment (i.e., an indication of no error) 
is given, the process returns to step 60 wherein the next information 
block is provided to the transmitter, ff an error is indicated (i.e.. no 
positive acknowledgment), then the transmission stage i is 

20 incremented, and the process returns to step 64. The process 
continues by inaementing the information stage one until positive 
acknowledgment is made. 

FIG. 5 is a flow chart illustrating staged turbo-decoding, 
i.e., at the receiver end, according to an embodiment of the present 

25 invention. In step 70, the decoding stage i is set to one (1 ). In step 
72, data samples are received, and in step 74, the received data 
samples are stored in memory. Turt>o-decoding is performed in step 
76. and a determination of a packet error is made in step 78. If not, 
then positive acknowledgment is made to the receiver in step 80. 

30 However, if a packet error is indicated in step 78, then the turtjo- 

decoding stage i is incremented in step 82. A test is made in step 84 
to determine whether a predetermined limit on the number of turtDo- 
decoding stages (max) has been reached. If so, then a request to 
restart the turtDo-decoding process is made in step 86. Otherwise, a 
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request for stage i turbo-decoding is made in step 88, and the - 
process returns to step 72. 

While the prefen'ed embodiments of the present 
invention have been shown and described herein, it will be obvious 
5 that such embodiments are provided by way of example only. 

Numerous variations, changes and substitutions will occur to those 
of skill in the art without departing from the invention herein. 
Accordingly, it is intended that the invention be limited only by the 
spirit and scope of the appended claims. 
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V\HAT IS CLAIMED IS: 

1 . A method for turboKXxjing in a communications 
system, comprising: 

turbo-encoding source information using a parallel 
concatenation of first and second convolutional codes, the step of 
5 turbo-encoding comprising first and second encoding steps, the first 
encoding step applying the first convolutional code to the source 
information to provide a first group of code bits, the second encoding 
step applying the second convolutional code to the source 
information after interleaving the source infonmation to provide a 
10 second group of code bits; 

puncturing the first and second groups of code bits; 

storing the punctured first and second groups of code 
bits in memory; 

transmitting the first and second groups of noh- 
15 punctured code bits to a receiver via a channel; 

storing data samples corresponding to the first and 
second groups of non-punctured code bits in memory; 

turbo-decoding the data samples corresponding to the 
first and second groups of code bits in at least two decoding stages 
20 and detenmining whether the transmitted code bits have been 
received in error; 

If a transmission error is detected, maintaining the data 
samples corresponding to the first and second groups of non- 
punctured code bits in memory and transmitting at least a 
25 predetermined portion of the stored punctured code bits to the 

receiver, and then turbo-decoding in at least two stages by combining 
the data samples corresponding to the first and second groups of 
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non-punctured code bits with data samples corresponding to the 
transmitted punctured code bits. 

2. The method of claim 1 wherein the step of puncturing 
comprises deleting code bits according to a predetermined 
puncturing pattern, and the step of turt)o-decoding comprises a 
depuncturing function for inserting neutral values for the punctured 

5 bits. 

3. The method of claim 1 wherein the first and second 
convolutional codes comprise systematic convolutional codes. 

4. The method of claim 3 wherein the step of puncturing 
comprises transmitting a single copy of the first and second code 
bits, which copy is used in each turtDo-decoding stage, 

5. The method of claim 1 wherein the step of 
determining whether the code bits have been received in error 
comprises a 16-bit cyclic redundancy check code. 

6. A communications system, comprising: 
a transmitter comprising: 

a turtxD-encoder for turtK>encoding source information, 
said turtH>encoder comprising a parallel concatenation of first and 
second convolutional codes, the turbo-encoder applying the first 
convolutional code to the source information to provide a first group of 
code bits, and applying the second convolutional code to the source 
information after interleaving the source information to provide a 
second group of code bits; 

a puncturing unit for puncturing the first and second 
groups of code bits; 

memory for storing the punctured first and second 
groups of code bits; 

said transmitter transmitting the first and second 
groups of non-punctured code bits via a channel to a receiver; 



10 
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the receiver comprising: 

memory for storing data samples corresponding to the 
first and second groups of non-punctured code bits; 

a turtXHjecoder for turbcnjecoding the data samples 
con-esponding to the first and second groups of code bits in at least 
two decoding stages and detennining whether the transmitted code 
bits have been received in en-or; upon detection of a transmission 
error, the turbo-decoder maintaining the data samples 
con-esponding to the first and second groups of non-punctured code 
bits in memory and requesting transmission of at least a 
predetermined portion of the stored punctured code bits to the 
receiver, the turtondecoder then turbo-decoding in at least two stages 
by combining the data samples corresponding to the first and 
second groups of non-punctured code bits with data samples 
con-esponding to the transmitted punctured code bits. 

7. The system of claim 6 wherein the puncturing unit 
deletes code bits according to a predetermined puncturing pattern, 
and the decoder inserts neutral values for the punctured bits. 

8. The system of claim 6 wherein the first and second 
convolutional codes comprise systematic convolutional codes. 

9. The system of claim 6 wherein the puncturing unit 
transmits a single copy of the first and second code bits, which copy 
is used in each turbo-decoding stage. 

10. The system of claim 6 wherein the decoder 
determines whether the code bits have been received in emar by 
using a 16-bit cyclic redundancy check code. 
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